package org.example.erp.domain;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.io.Serializable;
import java.util.Date;
import java.util.List;

import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;

/**
 * 销售出库单表
 * @TableName wm_product_salse
 */
@TableName(value ="wm_product_salse")
@Data
public class WmProductSalse implements Serializable {
    /**
     * 出库单ID
     */
    @TableId(type = IdType.AUTO)
    private Long salseId;

    /**
     * 出库单编号
     */
    private String salseCode;

    /**
     * 出库单名称
     */
    private String salseName;

    /**
     * 出货检验单ID
     */
    private Long oqcId;

    /**
     * 出货检验单编号
     */
    private String oqcCode;

    /**
     * 销售订单编号
     */
    private String soCode;

    /**
     * 客户ID
     */
    private Long clientId;

    /**
     * 客户编码
     */
    private String clientCode;

    /**
     * 客户名称
     */
    private String clientName;

    /**
     * 客户简称
     */
    private String clientNick;

    /**
     * 仓库ID
     */
    private Long warehouseId;

    /**
     * 仓库编码
     */
    private String warehouseCode;

    /**
     * 仓库名称
     */
    private String warehouseName;

    /**
     * 库区ID
     */
    private Long locationId;

    /**
     * 库区编码
     */
    private String locationCode;

    /**
     * 库区名称
     */
    private String locationName;

    /**
     * 库位ID
     */
    private Long areaId;

    /**
     * 库位编码
     */
    private String areaCode;

    /**
     * 库位名称
     */
    private String areaName;

    /**
     * 出库日期
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date salseDate;

    /**
     * 单据状态
     */
    private String status;

    /**
     * 备注
     */
    private String remark;

    /**
     * 预留字段1
     */
    private String attr1;

    /**
     * 预留字段2
     */
    private String attr2;

    /**
     * 预留字段3
     */
    private Integer attr3;

    /**
     * 预留字段4
     */
    private Integer attr4;

    /**
     * 创建者
     */
    private String createBy;

    /**
     * 创建时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date createTime;

    /**
     * 更新者
     */
    private String updateBy;

    /**
     * 更新时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date updateTime;

    /**
     * 逻辑删除字段 0:未删除 1:已删除
     */
    private Integer deleted;

    /**
     * 逻辑删除辅助字段
     */

    private Date deleteat;

    /**
     * 乐观锁
     */
    private Integer version;

    /**
     * 创建人id
     */
    private Long createUserId;

    /**
     * 修改人id
     */
    private Long updateUserId;

    @TableField(exist = false)
    private List<WmProductSalseLine> wmProductSalseLines;

    @TableField(exist = false)
    private static final long serialVersionUID = 1L;
}